## **LAB 5**

## OBJECTIVE: To design and simulate a **Half Adder Circuit** using VHDL, and verify its functionality using a testbench.

## TOOLS USED:

* VHDL (VHSIC Hardware Description Language)
* <https://www.edaplayground.com/> (for simulation)

**THEORY:**

A Half Adder is a basic combinational circuit that adds two single-bit binary numbers. It produces two outputs:

* Sum (S): XOR of inputs A and B
* Carry (C): AND of inputs A and B

## VHDL CODE

**DESIGN**

library ieee;

use ieee.std\_logic\_1164.all;

entity ha is

port( a: in std\_ulogic;

b: in std\_ulogic;

c: out std\_ulogic;

s: out std\_ulogic);

end ha;

architecture behave of ha is

begin

s <= a xor b;

c <= a and b;

end behave;

**TESTBENCH**

library ieee;

use ieee.std\_logic\_1164.all;

entity ha\_testbench is

end ha\_testbench;

architecture test of ha\_testbench is

component ha

port(a: in std\_ulogic;

b: in std\_ulogic;

c: out std\_ulogic;

s: out std\_ulogic);

end component;

signal ain, bin, carry, sum : std\_logic;

begin

half\_adder: ha port map (a => ain, b => bin, c => carry, s => sum);

process begin

ain <= '0'; bin <= '0'; wait for 1 ns;

ain <= '0'; bin <= '1'; wait for 1 ns;

ain <= '1'; bin <= '0'; wait for 1 ns;

ain <= '1'; bin <= '1'; wait for 1 ns;

assert false report "Reached end of test";wait;

end process;

end test;

Output:

![](data:image/png;base64,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)

CONCLUSION:

The Half Adder was successfully implemented and simulated in VHDL. The outputs of the simulation matched the expected values based on the truth table of a half adder. The testbench applied all input combinations and validated the behavior effectively.